CLAIMS 

What is claimed is: 

A method of performing jnultiple operations on a memory device, 
comprising: 

dividing the memory dej/ice into k partitions, wherein k is an integer 
greater than or equal to two; 

performing code operations from m code partitions out of k total partitions, 
wherein m is an integer greater than or equal to one; and 

tions from n data partitions out of k total partitions 
through low level functions accessed from the code partitions, wherein n is an 
integer greater than or equal to one. 



performing data open 



2. The method of claim 
do not overlap each other in 

3. The method of claim 



1 , wherein the data partitions and the code partitions 
the memory device. 

1 , wherein the m code partitions and the n data 



partitions equal the k total partitions 



The method of claim 



3, wherein each of the m code partitions are equal in 



size to each of the n data partitions 



5. 



The method of claim 



3, wherein the m code partitions and the n data 
partitions are fixed in memory space. 

6. The method of claim 1 , wherein the memory device is a flash memory. 

7. The method of claim 6, wherein the flash memory is a flash electrically 
erasable read only memory (EEPROM) array. 



i.. 



8. An apparatus comprising: 
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means for partitioning a memory device to enable multiple operations to 



preempted operation before entering 



the same time; and 

performed on the device to restore 



be performed on a memory device at 
means for tracking operations 
interrupted tasks. 

9. The apparatus of claim 8, further comprising a means for saving a 



an interrupt routine. 



10. The apparatus of claim 8, further comprising a means for restoring a 
preempted task following an interrupt routine. 

11. A memory array, comprising: 
a plurality of partitions; 

a status mode to provide partition status from the memory device; 
a read mode to read code and data from the memory device; and 
a write mode to write data to the memory device. 

12. The memory array of claim 1 1 , wherein the code is programmed into the 
memory array. 

13. The memory array of claim 1 1 , wherein the write mode is also capable of 
performing erase operations on data stored in the memory array. 



1 4. The memory array of claim 1 1j 
memory array. 

15. A method of handling a preelni 



, wherein the memory array is a flash 



comprising the steps of: 

saving the preempted state: 



ption within a flash memory device, 



Is 



reading the current state from the flash memory device; 

] 
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determining whether the flash memory device is busy; 



setting the memory device to a preempting state, wherein the preempting 
state is determined by the preempting command; 
issuing a preempting command; 
executing the preempting Command; and 



restoring the preempt 



16. The method of claim 1 



state, y 



I. fufffier a 

A 



comprising the step of suspending a 



preempted task if the flash memory device is busy prior to issuing a preempting 
command. 

17. The method of claim 15, further comprising the step of disabling interrupts 
prior to issuing the preempting command if the preempting command is a write, 
erase, or copy. 

further comprising the step of enabling interrupts 
preempting command. 
1 9. An apparatus, comprising; 

a memory device with k partitions, wherein k is an integer greater than or 
equal to two; 

low level functions to access the memory device; and 
a flag to indicate when a suspend operation has occurred. 



18. The method of claim 17, 
following the completion of the 



20. The apparatus of claim 



19, wherein the memory device comprises: 



and 



m code partitions, wherein m is an integer greater than or equal to one; 



n data partitions, wherein n is an integer greater than or equal to one. 
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21. The apparatus 

22. A method of perform 
steps of: 

placing the current s 
issuing the read conr 



of claijiri 19, wherein the memory device is a flash memory, 
hg a preempting copy operation, comprising the 



ate in read mode; 

mand to access data to be copied; 



retrieving the data tc be copied; 
placing the current st^te in status mode; 
disabling interrupts 

unlocking a memoiy block to be written; 
performing a write/setup; and 
writing the data toj memory. 

23. The method of claim 22 further comprising the step of enabling interrupts 
following the completion of the preempting copy operation. 

24. The method of claim 22, wherein the memory block is a flash memory 
block. 
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